<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@taglib uri="http://struts.apache.org/tags-html-el" prefix="html-el" %>
<%@taglib uri="http://struts.apache.org/tags-bean-el" prefix="bean-el" %>
<%@taglib uri="http://struts.apache.org/tags-logic-el" prefix="logic-el" %>
<%@taglib uri="/WEB-INF/tld/application.tld" prefix="app" %>

<html-el:form action="/cadastroUsuario.do">
	<html-el:hidden property="method" styleId="method"/>
	<table style="width:100%">
		<tr>
			<td align="center" valign="top" width="100%">
				<table style="width:700px">
					<tr>
						<td>
							<table cellpadding="1" cellspacing="4" bgcolor="#FAFAF5" style="width:100%;border:1px gray solid;border-bottom:0px">
								<tr>
									<td><b>Cadastro de Usuário</b></td>
								</tr>
							</table>				
							<table cellpadding="1" cellspacing="4" bgcolor="#FAFAF5" style="width:100%;border:1px gray solid">
								<tr>
									<td style="width:100%;padding:10px">
										<table style="width:100%">
											<tr>
												<td width="60" align="left">Nome:</td>
												<td align="left"><html-el:text property="nomeConsultar" styleId="nomeConsultar" size="30" maxlength="20"/></td>
											</tr>
											<tr>
												<td colspan="2">
													<table width="100%">
														<tr>
															<td height="10"></td>
														</tr>
														<tr>
															<td align="right">
																<html-el:button property="btnConsultar" styleClass="button" value="Consultar" onclick="consultar()"/>
																<html-el:button property="btnIncluir" styleClass="button" value="Incluir" onclick="incluirIniciar()"/>
															</td>
														</tr>
													</table>
												</td>
											</tr>
										</table>
									</td>
								</tr>
								<logic-el:present name="listaResultado" scope="request">
									<tr>
										<td style="height:1px;border-bottom:1px;border-bottom-style:ridge;">&nbsp;</td>
									</tr>
									<tr>
										<td style="width:100%;height:290px;padding:10px;vertical-align:top">
											<div style="width:100%;height:300px;overflow-x:auto;">
												<table cellpadding="0" cellspacing="1" style="width:100%;">
													<tr>
														<th align="center" class="tbResultadoConsultaHeader"></th>
														<th align="center" class="tbResultadoConsultaHeader">Nome</th>
														<th align="center" class="tbResultadoConsultaHeader">Login</th>
														<th align="center" class="tbResultadoConsultaHeader">Telefone</th>
														<th align="center" class="tbResultadoConsultaHeader">Perfil</th>
													</tr>
													<logic-el:iterate id="bean" name="listaResultado" scope="request" indexId="i">
														<tr class='tbResultadoConsultaLinha${i%2}'> 
															<td width="25" align="center" class="tbResultadoConsultaInfo"><html-el:radio property="idSelecionado" value="${bean.codigo}" onclick="selectItem(this)"/></td>
															<td align="left" class="tbResultadoConsultaInfo">${bean.nome}</td>
															<td align="center" style="width:110px" class="tbResultadoConsultaInfo">${bean.login}</td>
															<td align="center" style="width:110px" class="tbResultadoConsultaInfo">${bean.telefone}</td>
															<td align="center" style="width:110px" class="tbResultadoConsultaInfo">${bean.tipo.descricao}</td>
														</tr>
													</logic-el:iterate>
													<html-el:hidden property="idSelecionado"/>
												</table>	
											</div>							
										</td>
									</tr>
										<td style="width:100%;padding:10px;vertical-align:top">
											<table style="width:100%">
												<tr>
													<td align="right">
														<logic-el:present name="listaResultado" scope="request">
															<html-el:button property="btnSenha" styleId="btnSenha" styleClass="button" value="Enviar Senha" onclick="enviarSenha()" disabled="true"/>
															<html-el:button property="btnAlterar" styleId="btnAlterar" styleClass="button" value="Alterar" onclick="alterarIniciar()" disabled="true"/>
															<html-el:button property="btnExcluir" styleId="btnExcluir" styleClass="button" value="Excluir" onclick="excluir()" disabled="true"/>
														</logic-el:present>
													</td>
												</tr>
											</table>
										</td>										
								</logic-el:present>
							</table> 
						</td>
					</tr>
				</table>
			</td>
		</tr>
	</table>
	<div id="dialogIncluir" data-dojo-type="dijit.Dialog" title="Usuário - Incluir">
		<table style="width:400px;">
			<tr>
				<td>Nome:</td>
				<td colspan="4">
					<input type="text" id="nomeIncluir" title="Nome" size="50" maxlength="50"/>
				</td>
			</tr>
			<tr>
				<td>Login:</td>
				<td colspan="4">
					<input type="text" id="loginIncluir" title="Login" size="30" maxlength="25"/>
				</td>
			</tr>
			<tr>
				<td>Email:</td>
				<td colspan="4">
					<input type="text" id="emailIncluir" title="Email" size="50" maxlength="50"/>
				</td>
			</tr>
			<tr>
				<td>Telefone:</td>
				<td>
					<input type="text" id="telefoneIncluir" title="Telefone" size="12" maxlength="12"/>
				</td>
				<td></td>
				<td colspan="2"><input type="checkbox" id="adminIncluir" value="1"/> - Administrador</td>
			</tr>
			<tr>
				<td colspan="5" align="right">
					<html-el:button property="btnIncluir" styleClass="button" value="Incluir" onclick="incluir()"/>
				</td>
			</tr>
		</table>
	</div>
	<div id="dialogAlterar" data-dojo-type="dijit.Dialog" title="Usuário - Alterar">
		<table style="width:400px;">
			<tr>
				<td>Nome:</td>
				<td colspan="4">
					<input type="text" id="nomeAlterar" title="Nome" size="50" maxlength="50"/>
				</td>
			</tr>
			<tr>
				<td>Login:</td>
				<td colspan="4">
					<input type="text" id="loginAlterar" title="Login" size="30" maxlength="25" disabled="disabled"/>
				</td>
			</tr>
			<tr>
				<td>Email:</td>
				<td colspan="4">
					<input type="text" id="emailAlterar" title="Email" size="50" maxlength="50"/>
				</td>
			</tr>
			<tr>
				<td>Telefone:</td>
				<td>
					<input type="text" id="telefoneAlterar" title="Telefone" size="12" maxlength="12"/>
				</td>
				<td></td>
				<td colspan="2"><input type="checkbox" id="adminAlterar" value="1"/> - Administrador</td>
			</tr>
			<tr>
				<td colspan="5" align="right">
					<html-el:button property="btnAlterar" styleClass="button" value="Alterar" onclick="alterar()"/>
				</td>
			</tr>
		</table>
	</div>
</html-el:form>
<script language="javascript">

	dojo.addOnLoad(function() {
		onFocus("nomeConsultar");
	});

	jQuery(function($){
	   $("#telefoneIncluir").mask("(99)9999-9999");
		$("#telefoneAlterar").mask("(99)9999-9999");
	});

	function selectItem(i) {
		document.getElementById("btnAlterar").disabled = false;
		document.getElementById("btnExcluir").disabled = false;
		document.getElementById("btnSenha").disabled = false;
	}
	function consultar() {
		document.forms[0].method.value = "consultar";
		document.forms[0].submit();
	}
	
	function incluirIniciar() {
		document.getElementById('nomeIncluir').value = "";
		document.getElementById('loginIncluir').value = "";
		document.getElementById('emailIncluir').value = "";
		document.getElementById('telefoneIncluir').value = "";
		dijit.byId("dialogIncluir").show();
	}
	function incluir() {
		
		if(!mandatoryField('nomeIncluir')) {
			return false;
		}
		if(!mandatoryField('loginIncluir')) {
			return false;
		}
		if(document.getElementById('emailIncluir').value != "") {
			if(!validateEmail('emailIncluir')) {
				return false;
			}
		}
		if(document.getElementById('telefoneIncluir').value != "") {
			if(!validatePhone('telefoneIncluir')) {
				return false;
			}
		}
		
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroUsuario.do?method=incluir",
		        timeout: 10000,
		        handleAs: "text",
		        content: {nome:document.getElementById('nomeIncluir').value,
		        		  login:document.getElementById('loginIncluir').value,
		        		  email:document.getElementById('emailIncluir').value,
		        		  telefone:document.getElementById('telefoneIncluir').value,
		        		  admin:document.getElementById('adminIncluir').checked ? '1':'0'},
		        load: function(data) {
		        	if(data != "") {
		        		alert(data);
		        	} else {
		        		alert("Usuário incluído com sucesso!");
		        		dijit.byId("dialogIncluir").hide();
		        	}
		        },
				error: function(data, io) {
					alert(data.responseText);
		        }
		    });
		});
	}
	function alterarIniciar() {
		if(!mandatoryRadio('idSelecionado', 'Alteração')) {
			return false;
		}
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroUsuario.do?method=alterarIniciar",
		        timeout: 3000,
		        handleAs: "json",
		        content: {idSelecionado:getSelectedRadio('idSelecionado').value},
		        load: function(data) {
		        	document.getElementById('nomeAlterar').value = data.nome;
		        	document.getElementById('loginAlterar').value = data.login;
	        		document.getElementById('emailAlterar').value = data.email;
	        		document.getElementById('telefoneAlterar').value = data.telefone;
	        		document.getElementById('adminAlterar').checked = data.admin == 'SIM' ? true:false;
					dijit.byId("dialogAlterar").show();
		        },
				error: function(data) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
	}
	function alterar() {
		if(!mandatoryField('nomeAlterar')) {
			return false;
		}

		if(document.getElementById('emailAlterar').value != "") {
			if(!validateEmail('emailAlterar')) {
				return false;
			}
		}
		if(document.getElementById('telefoneAlterar').value != "") {
			if(!validatePhone('telefoneAlterar')) {
				return false;
			}
		}
		
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroUsuario.do?method=alterar",
		        timeout: 3000,
		        content: {idSelecionado:getSelectedRadio('idSelecionado').value,
		        		  nome:document.getElementById('nomeAlterar').value,
	        		      email:document.getElementById('emailAlterar').value,
	        		      telefone:document.getElementById('telefoneAlterar').value,
	        		      admin:document.getElementById('adminAlterar').checked ? '1':'0'},
		        load: function(data, ioArgs) {
		        	alert("Usuário alterado com sucesso!");
		        	consultar();
		        },
				error: function(data, ioArgs) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
		
		dijit.byId("dialogAlterar").hide();
	}
	function excluir() {
		if(!mandatoryRadio('idSelecionado', 'Exclusão')) {
			return false;
		}
	
		if(!confirm("Deseja realmente excluir?")) {
			return false;
		}	
		
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroUsuario.do?method=excluir",
		        timeout: 3000,
		        content: {idSelecionado:getSelectedRadio('idSelecionado').value},
		        load: function(data, ioArgs) {
		        	alert("Usuário excluído com sucesso!");
		        	consultar();
		        },
				error: function(data, ioArgs) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
	}
	
	function enviarSenha() {
		if(!mandatoryRadio('idSelecionado', 'Usuário')) {
			return false;
		}
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroUsuario.do?method=enviarSenha",
		        timeout: 10000,
		        handleAs: "json",
		        content: {idSelecionado:getSelectedRadio('idSelecionado').value},
		        load: function(data) {
					alert("Senha enviada com sucesso!");
		        },
				error: function(data) {
					alert("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
	}
	
</script>
